home *** CD-ROM | disk | FTP | other *** search
/ Almathera Ten Pack 3: CDPD 3 / Almathera Ten on Ten - Disc 3: CDPD3.iso / ab20 / ab20_archive / sounds / tools / edplayer-1.1a.lzh / EdPlayer1.1.DOC < prev    next >
Text File  |  1991-10-26  |  52KB  |  942 lines

  1.  
  2. ============================================================================
  3.                          EdPlayer version 1.1
  4.                              by Ed Mackey
  5. ============================================================================
  6.  
  7. All new releases and upgrades of PD/Shareware/Freeware by Ed & Al Mackey
  8. (such as EdPlayer) are uploaded FIRST to our official support BBS:
  9.      ____   __          ___  ___  _____  __   
  10.     /      /  \ |\  /| |__  |___)   |   /  \ |\ |            On-Line
  11.     \____  \__/ | \/ | |___ |  \    |   \__/ | \|          Information
  12.        __\______  ___       ___  ___  __                     Systems
  13.      ____/ |     |__  |    |__  /    /  \ |\  /| |\  /|
  14.            |     |___ |___ |___ \___ \__/ | \/ | | \/ |   Est. 10/17/87
  15.            |
  16.            |    Modem: (215) 464-6775       HST: (215) 464-4461
  17.  
  18.  Supporting:    Amiga/IBM/Mac/][gs/UNIX     Storage:    670 Megabytes
  19.  Message Confs: 160+ (23 Specific Forums)   File Areas: 50+ (& Personal)
  20.  Active Nodes:  8 (Soon to be 12 Nodes)     PCPursuit:  PAPHI
  21.  Baud Rates:    3/12/24/48/96/14.4 (HST)    Graphics:   ANSI/IBM/SkyPix
  22.  Online Doors:  30+ (6+ Categories)         Location:   Philadelphia, PA
  23.  FIDOnet:       * Coming Soon *             Users from: U.S./Canada/Europe     
  24.  
  25.  Features:      Teleconferencing            Global 'GO' Commands
  26.                 Multi-Player Games          Inter-User Chatting
  27.                 Live Conference RPG's       ANSI & Skypix Pictures
  28.                 Areas on ALL Topics         Special Over & Under 18 Bases
  29.                 Friendly Staff              Over 500 Active Users
  30.  
  31. ============================================================================
  32.  
  33. The sysop of Somerton is Eric Parkin, a good friend of mine.  If you call
  34. his board in the evening or at night, there's a chance you might meet me
  35. or Al (or both) messing around in the live teleconference area.  Such fun
  36. it is to have a BBS that understands multitasking, and has so many phone
  37. lines going into it.  It's running on an Amiga with a 25MHz '030.
  38. But enough about that...  You came here to read about EdPlayer...
  39.  
  40. ----------------------------------------------------------------------------
  41.  
  42. ORGANIZATION OF THIS FILE:
  43.     This file is organized so that you don't have to read all of it at
  44. once, but can skip to the part you want or need.  Aren't you glad??
  45.  
  46. I.   INTRODUCTION  -- Please read!!  Then you can fiddle with the buttons.
  47. II.  THE BUTTONS   -- After you fiddled, read this if you don't "get it".
  48. III. LED DISPLAY   -- What all the blinking things mean.
  49. IV.  AREXX/TELLED  -- Another way of controlling EdP.  ARexx is OPTIONAL!
  50. V.   ERROR CODES   -- Errors and POSSIBLE CAUSES!  Read if/when you get one.
  51. VI.  WHEW!         -- This has my address and some useful info!
  52.  
  53. ============================================================================
  54.  
  55.                           I N T R O D U C T I O N
  56.  
  57. ============================================================================
  58.  
  59. Hello, and welcome to EdPlayer!!
  60.  
  61. First, distribution:  EdPlayer is shareware.  You can distribute it by any
  62. means, including BBSs, PD disks, and FTP services like AB20, etc.  You can
  63. also distribute EdPlayer with your own programs, as long as you include a
  64. note that EdPlayer is freely distributable, and do not make any copyright
  65. claims on EdPlayer.  If you want to distribute EdPlayer with a commercial
  66. package, please contact me first (address at end of document).  I would
  67. LIKE for you to keep this document with EdPlayer whenever possible, because
  68. many important things are explained here (like EdPlayer's ARexx interface)
  69. that aren't explained anywhere else.  However, if you MUST distribute
  70. EdPlayer without this file, you may.  Also, note that if you distribute the
  71. kd_freq.library, you MUST keep its DOC file with it.  This is explained
  72. later in this file, in the "Buttons" section under "OPEN", the only button
  73. that uses the kd_freq.library.
  74.  
  75.                     EdPlayer is copyright 1991 Ed Mackey.
  76. ----------------------------------------------------------------------------
  77.  
  78. BUT, what IS it??
  79.  
  80. EdPlayer is a music player.  It can play both NoiseTracker modules and
  81. MED version 3.10 (or greater??) modules.  Note that SOME MED 3.00 modules
  82. will work also, however, others will show up as "Unknown or corrupt module"
  83. because MED 3.00 had a serious bug in the module-saving routines (it didn't
  84. word-align the chunks sometimes, and caused other MED players to GURU, but
  85. EdPlayer has a check for this and will only report a "corrupt module"
  86. error).  To fix a MED 3.00 or earlier module, simply load it into MED 3.10
  87. and save it back out as a MODULE.  As far as NoiseTracker modules go, I
  88. have an early version of the NoiseTracker player (the same one I used in my
  89. game MegaBall.  The source code said "Mahoney & Kaktus, Hallonsoft" and is
  90. freely distributable to the best of my knowledge).
  91.  
  92. What EdPlayer can be used for:
  93.  
  94. I had MANY uses in mind as I was designing EdPlayer.  I wanted a music
  95. player that could be used directly for entertainment, or multitask while
  96. the user did word-processing or whatever, and also be able to run from both
  97. ARexx and CLI scripts for use in IFF slide shows, presentations with
  98. background music (AmigaVision, DVideo III, Director 2, etc.), music for
  99. games written in AmigaBasic or other languages for which there are no
  100. music-playing routines available, and basically any situation at all where
  101. someone wants their Amiga to play some tunes.   ;->
  102.  
  103. ----------------------------------------------------------------------------
  104. Starting EdPlayer:  There are four ways to start EdPlayer...
  105.  ---> (1) Workbench Icon.        Brings up some CD-player like controls.
  106.       (2) CLI: "run EdPlayer"    Also brings up the CD controls.
  107.       (3) CLI: "run EdPlayer -i" Brings up a tiny "iconified" WB window.
  108.       (4) CLI: "run EdPlayer -h" NO user interface, ARexx port ONLY!
  109.  
  110. Note that I recommend using the "runback" command rather than "run" if you
  111. have it, so that the CLI window itself can close before EdPlayer does.
  112. NOTE: A simmilar effect can be achieved with "run <NIL: >NIL: EdPlayer".
  113.  
  114. Note that ALL 4 startup methods open the EDPLAYER message port, which can
  115. accept instructions from AREXX (if you have it) as well as the "telled"
  116. command explained below.
  117. ----------------------------------------------------------------------------
  118.  
  119. OK, now that you know how to run it, you can start playing with it even
  120. before you finish reading these DOCs.  This is because there is an ONLINE
  121. HELP FUNCTION that is self-explanatory.  However, this function includes a
  122. lot of scrolling text, and so when you get tired of reading that, you can
  123. come back here because ALL OF THE ONLINE HELP IS ALSO AVAILABLE HERE IN THE
  124. DOCs.  Plus, some features, like the AREXX port, are ONLY described here in
  125. the DOCs!!
  126.  
  127. ============================================================================
  128.  
  129.               A N D   N O W ,   T H E   B U T T O N S :
  130.  
  131. ============================================================================
  132.  
  133. If you're reading this, I hope you have tried playing with EdPlayer a bit. 
  134. You know that there are a lot of buttons on the main panel that appears
  135. when you run the program.  Here they are, left-to-right, slowly working
  136. downward from the top.  (There are no keyboard equivalents for any of
  137. these buttons in this release.  You'll have to use your mouse.  Sorry).
  138.  
  139. POWER:  This exits EdPlayer rather immediately.  No "Are you Sure?" prompts
  140.         or anything, because they sometimes annoy me.  Of course, all the
  141.         proper shutdown routines are run, such as unloading the current
  142.         song, etc.  Note that the close gadget in the "iconified" WB window
  143.         has this same function (see ICONIFY below).
  144.         (ARexx/telled users: see KILL, SELF in ARexx section)
  145.  
  146. "T":  Tempo control.  NoiseTracker modules can have different tempos
  147.       depending on whether you are in PAL or NTSC mode.  This button
  148.       toggles between the two tempos, with the current status appearing in
  149.       the LED display.  Note that this option is memorized "per song" in
  150.       program mode (see PRG below).
  151.       (ARexx/telled users: see PALM, NORM, NTSC in ARexx section)
  152.  
  153. HELP:  This is the "Online Help Function."  I call it "online" because you
  154.        can get help while you are using EdPlayer.  (Of couse, this being an
  155.        Amiga, you can multitask and get help from the DOCs while you are
  156.        using EdPlayer too.  Oh, never mind.)  Anyway, you click here to
  157.        turn help on, then click on the buttons you want help with, and then
  158.        click here again to turn help back off.
  159.  
  160. "|<":  EJECTs current song, moves to previous program selection, and
  161.        displays title of that selection.  You can use this to flip through
  162.        a program, select where you want to start, and press PLAY to start.
  163.        (see PRG below).
  164.        (ARexx/telled users: see PREV in ARexx section)
  165.  
  166. ">|":  Same as "|<" above, but moves to NEXT prg selection rather than the
  167.        previous one.
  168.        (ARexx/telled users: see NEXT in ARexx section)
  169.  
  170. PRG:  OK, now it's time to explain programs.  A "program" is a list of
  171.       module filenames that EdPlayer can memorize, along with two options
  172.       per name (PAL / NTSC and FADE / NO FADE).  When such a list exists,
  173.       EdPlayer will attempt at the end of each song to load and play the
  174.       next song in the program, using the options for that song.  The two
  175.       buttons listed above this one scroll through the program.  Sorry, but
  176.       in this version there is no "Random play" function.  I do plan to
  177.       add it in a later version, however.  Now about the PRG button itself:
  178.       Be careful with this button!!  It's main use is for ERASING the
  179.       current program!  This is because CREATING programs is more easily
  180.       done with the OPEN button described below.  If EdPlayer has a program
  181.       in memory, the "PRG" LED will light up on the display.
  182.       (ARexx/telled users: see JUKE, LOAD in ARexx section)
  183.  
  184. EJECT "^":  Unloads current song, freeing lots of CHIP memory.  Does NOT
  185.             erase current program.
  186.             (ARexx/telled users: see EJEC in ARexx section)
  187.  
  188. OPEN:  For this one, you need the kd_freq.library version 2.0 or higher in
  189.        your LIBS: directory!  This library might have come with the
  190.        EdPlayer archive, because its copyright notice is as follows:
  191.  
  192. >>If you want to use 'kd_freq.library' in any freely distributable program,
  193. >>you may include the 'kd_freq.library' file as long as you also include the
  194. >>'FR_User.DOC' file and mention 'Copyright 1990  Khalid Aldoseri'.
  195.  
  196.        Oh yes, the author of this library, Khalid Aldoseri, can be reached
  197.        at the following address:
  198.                         Khalid Aldoseri
  199.                         P.O. Box 505
  200.                         Manama, Bahrain.
  201.                         Fax: (973) 694777
  202.                       Compuserve 75166,2531
  203.        And I almost forgot to mention that this library is Copyright 1990
  204.        Khalid Aldoseri.  Now that you have the kd_freq.library, you can use
  205.        the EdPlayer OPEN button to bring up it's file requester.  With this
  206.        requestor, you should select the filename of a module you want to
  207.        hear.  If there is no program, the song will load and begin to play.
  208.        However, if there IS a program (even an empty one created with PRG),
  209.        the song's name will be added to the program.  NOTE THAT A MUCH
  210.        EASIER way to make programs is with the file requester's "Extended
  211.        Select" feature.  To use this, hold down the SHIFT key and click
  212.        several module filenames.  As you click them, they light up, and
  213.        when you press "OK", ALL of the filenames will be added, in
  214.        alphabetical order, to the END of the current program.  If no
  215.        program exists when you use this feature, one will automatically be
  216.        created.  To start any program, press PLAY.
  217. ***    NEW for EdP v1.1:  EdPlayer can now use the req.library if it can't
  218.        find the kd_freq.library.  You have to be a little more careful
  219.        with req, however:  it lets you specify drive names ("DF0:") instead
  220.        of volume names ("MyMods1:") so if you have 30 disks and you
  221.        program them all as DF0:something, you're going to be CONFUSED!!
  222.        (ARexx/telled users: see LOAD, PLAY, JUKE in ARexx section)
  223.  
  224. PLAY "|>":  This button has many functions.  If no song is loaded, it will
  225.             try to get a module name from the program and load & play it.
  226.             If a song IS loaded, but not playing, it will ignore the
  227.             program and play the current song.  If a song is ALREADY
  228.             playing, this button will PAUSE it (either immediately or
  229.             fade-to-pause, see FADE).  Finally, if a song is paused, and
  230.             you press this, the song will continue, either immediately or
  231.             fade-back-in (see FADE again).
  232.             (ARexx/telled users: see PLAY, PAUS, CONT in ARexx section)
  233.  
  234. STOP:  This button has a square on it.  It stops the music IMMEDIATELY,
  235.        regardless of the state of the "fade" light.  If you want a
  236.        fade-out, fade to a PAUSE and then press STOP.  I made it this way
  237.        because I found that in practice, when people press STOP, they just
  238.        want the music to STOP right there because they're debugging or
  239.        something, and fading is mostly for song changes in a program.
  240.        NOTE that you can NOT continue after a STOP!  You must start again
  241.        from the beginning of that song.  If you wanted to continue, you
  242.        should have pressed PAUSE (a function of the PLAY button above).
  243.        (ARexx/telled users: see STOP, FADE in ARexx section)
  244.  
  245. LOOP:  This button has a little curved arrow on it, signifying a loop.  It
  246.        will toggle on and off the similar-looking LOOP LED on the display.
  247.        When this LED is lit, the current song will loop to the beginning
  248.        (or wherever the composer decided it would loop to) and keep
  249.        playing.  In program mode, each song will come to an end, but the
  250.        whole program will loop when it runs out of titles.  When this LED
  251.        is NOT lit, the current song will end (either immediately or
  252.        fade-to-stop, see FADE) and in program mode, the program will end
  253.        when it runs out of titles (but it won't be erased).  Note that
  254.        certain MED modules have a special "STOP" command ($FFE) encoded
  255.        into the end of the song, and these modules will NEVER LOOP,
  256.        regardless of this button.
  257.        (ARexx/telled users: see LOOP, AUTO in ARexx section)
  258.  
  259. FADE:  This button has a triangle that is supposed to signify volume fading
  260.        away (sort of).  Whenever you use PAUSE or CONTINUE, or when the
  261.        song reaches an end just before a program change, the song can
  262.        either stop/start immediately, or gradually fade out/in.
  263.        NOTE the two kinds of music modules:
  264.          1) The kind where the music comes to a nice stopping point at
  265.             the end, and doesn't need to loop.
  266.          2) The kind where the end of the score sounds like it should
  267.             keep going!  Then it loops to somewhere in the middle.  These
  268.             tunes appear to have NO stopping place, because anywhere you
  269.             stop them makes it sound abruptly cut off.
  270.        Most module players only handle the first kind of tune.  But with
  271.        EdPlayer's FADE function, a song of the second type can loop when
  272.        it reaches the end, and then fade to a stop in part of the song
  273.        you already heard (where it will be after a loop, obviously).
  274.        This puts a very nice pseudo-ending on an otherwise endless tune.
  275.        HOWEVER, if you apply this to a song of the first type, you get
  276.        something that sounds like it stops, re-starts, and then fades.
  277.        A LOT of people reported this as a BUG!  Well, it's **NOT**!!!
  278.        Just turn FADE OFF for those songs, with this nice FADE button!  The
  279.        button toggles on and off the similar-looking FADE LED on the
  280.        display.  When this LED is lit, EdPlayer will try to fade the song
  281.        as mentioned.  When this LED is dark, EdPlayer will just do instant
  282.        stops and starts.  If a song comes to an end, and LOOP is off (or
  283.        program is on) and FADE is on, the song will LOOP anyway, but begin
  284.        fading to a stop, and the program change will occour after the fade.
  285.        Note that this button has NO effect on (1) the STOP button or (2)
  286.        MED modules that have the special STOP effect ($FFE) encoded into
  287.        them.  However, these MED modules WILL trigger program changes, of
  288.        course.  SETTING the fade rate:  see the "PAUS" command in the
  289.        ARexx section!!
  290.        (ARexx/telled users: see PAUS, LOOP, AUTO, FADE in ARexx section)
  291.  
  292. FILTER:  This button looks like a dot with little waves coming out of it.
  293.          It has a similar-looking FILTER LED on the display panel that
  294.          shows the status of the Amiga's audio filter, which is also
  295.          displayed by your Amiga's so-called "power" LED.  I have no clue
  296.          why the Amiga's power LED does this.  If anyone knows please tell
  297.          me.  Anyway, this button turns it on and off, however, this is THE
  298.          most useless feature in all of EdPlayer, because the filter is
  299.          also automatically handled by the music playing routines.
  300.          (ARexx/telled users: You can't blink the filter!  Ha, ha!!
  301.           You'll just have to live without this oh-so-useful function.)
  302.  
  303. ICONIFY:  This button looks like a WB 1.3 back gadget, but it's NOT the one
  304.           in the title bar.  It gets rid of the CD-player like controls,
  305.           saving a bit of CHIP mem, and produces a tiny "iconified" window
  306.           on the WB screen.  This window has only two options: The close
  307.           gadget will exit EdPlayer (see Power above), and the right mouse
  308.           button, if pressed when the window is selected, will bring back
  309.           the CD-player look.  Of course, all the EdPlayer functions remain
  310.           in effect in this mode, like program changes and ARexx messages. 
  311.           Plus, this mode saves a bunch of CPU time, because EdPlayer can
  312.           sleep rather than updating the display every video cycle.  If you
  313.           REALLY need to conserve memory, you should hide EdPlayer
  314.           altogether and then close the WB screen, using one of the ARexx
  315.           commands and then some utility for closing WB:
  316.           (ARexx/telled users: see MENU, ICON, HIDE in ARexx section)
  317.  
  318. DISPLAY:  This button looks like two calculator 8's.  It toggles between
  319.           four display modes, described in the LED Display section below.
  320.  
  321. MIDI:  This button is supposed to look like a MIDI plug.  Sort of.  Anyway,
  322.        it toggles MIDI on and off.  The MIDI LED on the display shows the
  323.        current status of MIDI.  When the light is off, your serial port is
  324.        free for things like downloading, etc., and when the light is on,
  325.        the serial port is allocated for MED modules to send MIDI data with.
  326.        Note to midi.library users!!!!  See "MIDL" in ARexx section!
  327.        (ARexx/telled users: see MIDI, MIDL, NOMI in ARexx section)
  328.  
  329. VOLUME SLIDE:  Well, what do YOU think it does?  It controls the volume of
  330.                a piece of music.  Also, it might NOT be such a good idea to
  331.                fuss around with this thing while the music is already
  332.                trying to FADE in/out of its own accord due to the FADE LED.
  333.                (ARexx/telled users: see VOLU in ARexx section)
  334.  
  335. INFO BAR:  You can click in the space between EdPlayer's "feet" to display
  336.            the name and author info of the current song.  Also, this space
  337.            shows other useful stuff like the online help, and the version
  338.            info when you first start EdPlayer or when you come out of an
  339.            Iconify or HIDE.  NOTE TO MODULE AUTHORS:  If you want to create
  340.            some "author info" to appear in this bar whenever your module
  341.            plays, there are 2 ways:  (1) For NT-MODs:  Create some
  342.            instrument names preceded by a "#".  Each instrument name in the
  343.            NT-MOD that starts with a # will be linked together (add your
  344.            own spaces!) and displayed in the bar.  (2) For MED MODs:
  345.            Create an "annotext" as the MED documentation describes.
  346.            SPECIAL EFFECTS:  EdPlayer can handle some neat effects in the
  347.            author info of a module (NT OR MED).  These effects all start
  348.            with a <`> mark, NOT to be confused with the more ordinary <'>
  349.            mark.  PLEASE NOTICE the difference between ` and ' !!!!
  350.            The ` key, on my American keyboard, is in the top-left, just
  351.            under the ESC key.
  352.            Here are the effects:  (lowercase letters ONLY!)
  353.                      `s  =  SLOW.  Text will scroll at 1/4 normal speed.
  354.                      `n  =  NORMAL.  Text resumes normal scroll speed.
  355.                      `f  =  FAST.  Text goes THREE TIMES normal speed!!
  356.  
  357.                      `r  =  RED.  Text from here on will be red.
  358.                      `y  =  YELLOW
  359.                      `g  =  GREEN
  360.                      `t  =  TAN   (EdPlayer's tanish color used on buttons)
  361.                      `p  =  ICKY, ICKY PURPLE!!
  362.                      `w  =  WHITE, the default.
  363.  
  364.                      ``  =  ` (if you really want a ` mark to appear).
  365.  
  366.            To use any of these effects, just insert them in the author text
  367.            of your module.  Note that using a ` mark at all will FORCE the
  368.            text to scroll, even if it was short enough to fit all on the
  369.            lo-res screen at once (NOT LIKELEY!!).
  370.  
  371. ============================================================================
  372.  
  373.                            L E D   D I S P L A Y
  374.  
  375. ============================================================================
  376.  
  377. Ah, such a complicated, confusing display.  Not really!  It's pretty simple
  378. when you break it down.
  379.  
  380. OK, I'm going to start in the BOTTOM-LEFT, and go RIGHT.  You'd better be
  381. looking at the display while you're reading this (I'm looking at it while
  382. I write it)!  First, in the bottom-left, you see the PRG LED.  It's
  383. probably dark, so look very closely.  It only lights up if you have a
  384. "program" active (see PRG in the button section above).  Next, to the right
  385. of PRG, is a little bent arrow.  This is the LOOP LED (see LOOP in the
  386. button section).  To the right of that is the FADE LED which, by default,
  387. is lit up when EdPlayer starts (see FADE in the button section above). 
  388. Then there is the FILTER LED (again, see FILTER above).  Then there are two
  389. LEDs that say "PAL" and "NTSC".  When EdPlayer starts, whichever mode you
  390. are in should be lit up.  You can change this for tempo correction of
  391. NoiseTracker modules, but they BOTH go dark for MED modules which need no
  392. such correction.  To change it, see "T" (Tempo) in... you guessed it... the
  393. button section, above.
  394. ----------------------------------------------------------------------------
  395. AND NOW, THE LEDs which are *NOT* explained in the button section, above.
  396.                       YEAH!!
  397.  
  398. To the right of PAL/NTSC you see something like a four-bar VU-meter.  As
  399. the Amiga has four built-in voices, it shouldn't be too hard to figure out
  400. what this does.  Fun to watch when playing a song!  To the right of that,
  401. you see a few LEDs (we're now as far right as we can go)!  The "NT-MOD"
  402. will light up when EdPlayer has a NoiseTracker module loaded, and
  403. "MED 3.10" will light up when there is a MED module loaded.  "PAUSE" will
  404. light up when in pause mode, and will BLINK when EdPlayer is FADEing to a
  405. pause.  The "MIDI" light is special:  The whole MIDI thing lights up when
  406. MIDI (direct or midi.library) is active, BUT, when a song is playing, the
  407. five red dots (representing MIDI prongs on the end of a MIDI cable) will go
  408. dark again, and BLINK as MIDI messages are passed out of EdPlayer!  I think
  409. this is a neat effect during MIDI songs.
  410. ----------------------------------------------------------------------------
  411. And finally, the digits.  These digits are controlled by the "Display"
  412. button (which looks like two calculator 8's) and have FOUR MODES.
  413.  
  414. MODE 1:  Below the digits you see TRACK, POS, and TOTAL.  When a song is
  415.          loaded, it's current position will be displayed above "POS",
  416.          with the total number of positions being displayed above "TOTAL."
  417.          Above "TRACK" you may see a program number, if this song is
  418.          part of a program.  SPECIAL CASE:  If you are in a program, but no
  419.          song is currently loaded, the "POS" will disappear, allowing
  420.          "TRACK" and "TOTAL" to work together, displaying the current and
  421.          total number of songs in the program, respectively.
  422.  
  423. MODE 2:  In this mode, you see LINE, POS, and PATT below the digits.  The
  424.          "Pos" light is exactly the same as in mode 1, displaying the
  425.          song's position.  The "LINE" shows a much more exact position
  426.          inside the POS itself, and "PATT" shows the current pattern
  427.          number being displayed.  This mode is for people who like to
  428.          follow the progress of their songs through the player, and also
  429.          for people like myself who just want to see all the busy, changing
  430.          numbers going on.
  431.  
  432. MODE 3:  This mode just displays your Amiga's system time.  You can
  433.          distinguish this mode by the "AM" or "PM" that lights up.  To set
  434.          the time, just use the AmigaDOS "Date" command, or some other
  435.          utility.  Actually, if you have a battery-backed-up clock in your
  436.          Amiga, the time should already be set from your startup-sequence
  437.          via the "SetClock Load" command.  Why am I explaining this?!
  438.          Go read your Amiga's manual if you're confused!
  439.  
  440. MODE 4:  This mode just displays the system date, in MONTH, DAY, YEAR
  441.          format.  You can distinguish this mode from the others because NO
  442.          funny LEDs like "Track" or "AM" or even ":" or "/" come on.
  443.          To set the date, see MODE 3 above.
  444.  
  445. Well that about wraps it up for the LED display.  Oh yes, if EdPlayer tries
  446. to display a number greater than 99, two dashes "--" should appear instead.
  447. Also, the two dashes appear above "TRACK" when there is a program, but no
  448. selection in the program is "current".  Pressing PLAY at this point will
  449. move the current selection to 01 if necessary before loading & playing.
  450.  
  451. Note that there is NO LIMIT on the number of songs in a program!!  NOT 99,
  452. NOT 65536, OR ANYTHING LIKE THAT!  This is because I used Amiga exec's
  453. wonderful doubly-linked lists to handle the list of names.  SO, you can
  454. keep adding names to a program until your whole Amiga's memory is full of
  455. nothing but filenames, and you may not have enough memory left to actually
  456. load a song, but you will NEVER get a "Too many names in Program" error. 
  457. Well, actually, if the memory allocation for the filename storage fails,
  458. you can get an out-of-memory error from EdPlayer, but if you're THAT close
  459. to being out of memory, you're probably headed for a GURU real soon!
  460. Anyway, just thinking about typing all those millions of filenames makes my
  461. fingers hurt!
  462.  
  463. ============================================================================
  464.  
  465.                   A R E X X / T E L L E D   S E C T I O N
  466.  
  467. ============================================================================
  468.  
  469. EdPlayer has a special message port.  This port is more than an ARexx port,
  470. because it can accept both ARexx messages and special "EdPlayer" messages
  471. in the same port.  The reason for this is that some unfortuneate people
  472. still don't have ARexx!  What are you guys waiting for??
  473.  
  474. Anyway, included in this archive are two programs and their respective
  475. source codes, called "Telled" (Telled.asm) and "cteled" (cteled.c).  The
  476. two are almost identical:  Telled was written in Assembly, being as SMALL
  477. as possible, for easy use in script files.  Cteled was written in Aztec C,
  478. and is somewhat larger because it actually returns error messages on the
  479. screen.  Both of these programs transmit the special "EdPlayer" messages so
  480. that ARexx is not required.  Their source codes are provided in case you
  481. want to write your own programs that transmit these messages.  However, it
  482. is STRONGLY RECOMMENDED that you look up in your ARexx manual the proper
  483. way of sending true ARexx messages, so that you know how to send messages to
  484. other ARexx applications, not just EdPlayer.
  485.  
  486. For those of you making script files:  If you have ARexx, you'll almost
  487. certainly want to make ARexx scripts instead of CLI scripts.  For that,
  488. use an "address 'EDPLAYER'" type command.  Again, see your ARexx manual for
  489. more details (Are they giving out ARexx manuals with new WB 2.0?  I sure
  490. hope so!  Will someone with WB 2.0 please tell me how much ARexx 
  491. documentation came with it?)  ANYWAY, for you people without ARexx, you're
  492. stuck making CLI scripts!  For this, use "telled" or "cteled" as described
  493. here:  NOTE!: the parameters are different.  Telled does NOT use quotes,
  494. while cteled DOES:
  495.  
  496. CORRECT:
  497.      >>>>   telled PLAY mod.cream of the earth
  498. ;Note that telled NEVER needs any quotes no matter how many spaces are
  499. ;in the line.
  500.  
  501.      >>>>   cteled "PLAY mod.cream of the earth"
  502. ;Note that cteled NEEDS quotes, and all parameters go in the SAME
  503. ;set of quotes, because EdPlayer will parse it, NOT cteled.
  504.  
  505.      >>>>   telled play mod.cream of the earth
  506. ;*** NEW for EdP v1.1: Commands are no longer case-sensitive,
  507. ;    EXCEPT the parameter on the "MIDL" command which needs to be
  508. ;    case-sensitive for looking up a midi_destination.
  509.  
  510. INCORRECT:
  511.             telled "PLAY mod.test module"   ;telled NEVER needs quotes
  512.                    X                    X
  513.  
  514.             cteled "PLAY" "mod.test module" ;put ALL in one set of quotes
  515.                         X X
  516.  
  517. Well, I hope you can get the hang of that.  There should be some example
  518. scripts in the archive, for more examples of sending commands.
  519.  
  520. ----------------------------------------------------------------------------
  521.  
  522. Now it's time for a complete list of commands.  Note that you may give ANY
  523. of these commands to EdPlayer by (1) using the CLI to issue "telled" or
  524. "cteled" as shown above, or (2) send the commands via ARexx to the ARexx
  525. port "EDPLAYER" (port name is all caps).
  526.  
  527. I'll list the commands in the order they were created.  Note that each one
  528. is FOUR LETTERS.  Any needed parameters should follow the command, separated
  529. from it by ONE SPACE.
  530.  
  531. Parameters in [<brackets>] are optional.
  532.  
  533. Parameters in <these things> are required!
  534.  
  535. LOAD <filename>
  536.        This command is used to load a module into EdPlayer.  EdPlayer
  537.        automatically figures out what module type it is, but does not yet
  538.        start to play it.  This command can NOT be used with programs!  It
  539.        erases the current program.  If you want to use programs, see JUKE
  540.        below.  Anyway, LOAD will wait until the module finishes loading
  541.        before it returns, so it can report if there was an error or not.
  542.        Note:  ALWAYS use a FULL PATH with LOAD, because the current
  543.        directory of EdPlayer may not match the current directory of the
  544.        program sending the command.
  545. ***    NEW for EdP v1.1:  If you want to load a PP encrypted module, you
  546.        can do this:   LOAD volume:path/modulename|password
  547.        (Please note the LACK of spaces around the "|").
  548.        If you don't give a password when needed, a password requester opens.
  549.  
  550. PLAY [<filename>]
  551.        This command can be used with or without the parameter.  If it is
  552.        given with no parameter, it will attempt to play the current song. 
  553.        If there is a parameter, it will call LOAD first, and then PLAY.  
  554.        This command will wait for the module to load, so it can report
  555.        errors like LOAD does, but it will return once the song begins to
  556.        play.  Note:  This is NOT the same as the PLAY button on the CD,
  557.        because there is no PAUSE feature here, and neither is there
  558.        auto-loading from the current program.  For these features,
  559.        see PAUS, CONT, and NEXT.
  560.  
  561. STOP
  562.        Stops the music immediately, just like the STOP button.
  563.  
  564. EJEC
  565.        EJECts the current song, un-loading it from your CHIP mem.
  566.        (Just like the EJECT button!)  Does nothing to your program.
  567.        see ERAS
  568.  
  569. VOLU <volume>
  570.        Sets the music's volume, and affects the volume slide on the CD
  571.        player panel.  <volume> can be an integer from 0 to 64.
  572.        see FADE
  573.  
  574. PAUS [<rate>]
  575.        This will pause the music.  If there is no parameter, the music will
  576.        pause immediately.  If there is a <rate>, then the music will fade
  577.        to a pause.  Common <rate>s are:  1 = Very slow, 2 = slow,
  578.        4 = initial default fade rate from CD panel, 8 = medium fast, 16 =
  579.        fast. Integers from 1 to 32 usually work OK.  NOTE: Entering a new
  580.        PAUSE rate may not affect the end-of-song fade-out rate, BUT, it
  581.        WILL set a new default for the panel's rate for everything.  So next
  582.        time someone uses the panel to fade something, it will happen in the
  583.        last-used <rate>.  This side-effect on the panel goes for ALL
  584.        EdPlayer commands that use <rate>, such as CONT, AUTO, FADE, etc.
  585.        It is, in fact, the ONLY way to set the panel's fade rate!  Maybe
  586.        in future versions there could be a slider or something so that the
  587.        rate can be set from the panel itself?....
  588.        see CONT.
  589.  
  590. CONT [<rate>]
  591.        This will make the music continue, if it has been PAUSed.  If no
  592.        <rate> is given, the rate from the last PAUS will be used.  For a
  593.        description of <rate>s, see PAUS.
  594.  
  595. FADE [<rate>]
  596.        This is for fading the song to a STOP.  You cannot continue after
  597.        this!!  The <rate> works like in PAUS, except that if it is not
  598.        specified, it defaults to 4, taking the panel's rate to 4 along
  599.        with it, probably.  (Yet another feature that needs testing!)
  600.  
  601. AUTO [<rate>]
  602.        This command is for automatically getting a song (or program) to
  603.        stop at the end (this is the default when EdPlayer starts).  If no
  604.        <rate> is specified, the song will stop immediately when it reaches
  605.        the end, otherwise, the song will loop and start to fade to a stop
  606.        at the specified <rate>.  During programs, it will set the fade-out
  607.        rate at the end of each song, as well as telling the program not
  608.        to loop.  If you set this rate but still want your program to loop,
  609.        just issue a LOOP command afterwards.  For a descripton of <rate>s,
  610.        see PAUS.
  611.  
  612. LOOP
  613.        The current song or program will loop and keep playing, instead of
  614.        stopping, when it reaches the end.  This is the opposite of AUTO.
  615.  
  616. KILL
  617.        This has the same effect as pressing the "Power" button:  The
  618.        current song STOPs, gets EJECted, the program is erased, and then
  619.        EdPlayer exits the system, all very quickly.  It's a good idea to
  620.        ask the user if he/she wants this before you send a KILL command.
  621.  
  622. JUMP <position>
  623.        This is an interesting command.  It tells EdPlayer that on the next
  624.        position change (a position currently shows up as "POS" on the
  625.        CD panel), the music should jump to the specified position rather
  626.        than just proceeding to the next one.  My brother created a perfect
  627.        example of what this can be used for:  He wrote a module (in MED)
  628.        that had several sections, each section ending in a $B command for
  629.        looping.  Then he turned EdPlayer's LOOP on, and in a DeluxeVideoIII
  630.        presentation, had EdPlayer start playing this song.  Of course, it
  631.        got caught in the first looping section.  But then, as the
  632.        presentation continued (it was more like a game actually), he sent
  633.        JUMP commands to EdPlayer to play the different sections.  As the
  634.        user moved from one part to the next, the music changed to match the
  635.        current place in the game.  It was a really neat effect.  Anyway, if
  636.        this DVideo game ever becomes playable, I'm sure he'll distribute
  637.        it....
  638.  
  639. SELF [<rate>]
  640.        This command works exactly like AUTO, except that at the end of the
  641.        song's fade-out, EdPlayer KILLs itself (exits the system).  I don't
  642.        think I ever updated this command for use with programs, because
  643.        quite frankly I never found a use for it myself.  If you use it, and
  644.        want it updated, tell me!  (SELF stands for SELF-destruct)
  645.        (Updating would mean having it wait for the end of a program, rather
  646.        than the end of a song, before the self-destruct.)
  647.  
  648. NORM
  649.        This command is for controlling the tempo correction on NoiseTracker
  650.        modules.  It sets it back to NORMal, with no correction.
  651.        see NTSC, PALM
  652.  
  653. NTSC
  654.        This command is like NORM, but if EdPlayer thinks your machine is
  655.        running in PAL Mode, it will try to make NT modules sound like they
  656.        are being played at NTSC tempo.  If you execute NTSC on an NTSC
  657.        machine, EdPlayer should automatically call NORM instead.
  658.        see NORM, PALM
  659.  
  660. PALM
  661.        (PALM = PAL Mode)  This command is the opposite of NTSC:  If you
  662.        have an NTSC machine, EdPlayer will try to make the modules sound
  663.        like they are being played at PAL tempo.  If you call PALM on a PAL
  664.        machine, EdPlayer should do a NORM instead.
  665.        see NORM, NTSC
  666.  
  667. MENU
  668.        This command will bring up EdPlayer's CD-like control panel if it's
  669.        not visible, and redraw it if it is.  The EdPlayer version
  670.        information will be re-displayed.
  671.        see ICON, HIDE
  672.  
  673. ICON
  674.        This command will close the CD display and create the iconified WB
  675.        window that also appears when someone presses the "ICONIFY" button
  676.        or starts EdPlayer with the -i option.  Selecting this WB window
  677.        and pressing the right mouse button will bring back the CD panel.
  678.        see MENU, HIDE
  679.  
  680. HIDE
  681.        This command will remove EdPlayer's user interface altogether, as if
  682.        you had started EdPlayer with the -h option.  This allows WB to be
  683.        closed if necessary, but is not really recommended because the user
  684.        has no way to undo this using the mouse alone.  It can only be
  685.        undone with the MENU or ICON commands, above.
  686.        see MENU, ICON
  687.  
  688. MIDI
  689.        This is for direct MIDI on MED modules.  If any midi.library
  690.        resources have been allocated, they are deallocated and the library
  691.        is closed.  Then, EdPlayer tries to allocate the serial port for
  692.        direct MIDI output, using the default MED MIDI routines.  This is
  693.        the mode that the MIDI button on the panel uses.  Safe to call even
  694.        when a module is playing, because a playing MED module will be
  695.        paused VERY briefly during the allocation & init of the MIDI stuff.
  696.        see NOMI, MIDL
  697.  
  698. NOMI
  699.        NO MIdi.  Deallocates any and all MIDI-related resources, such as
  700.        the midi.library or serial port.  Safe to call even when a module
  701.        is playing.
  702.        see MIDI, MIDL
  703.  
  704. MIDL [<midi_destination>]
  705.        MIDi.Library.  If you own the midi.library by Bill Barton, you can
  706.        use this command to take over MED's MIDI output:  Instead of
  707.        allocating and directly controlling the serial port, EdPlayer will
  708.        attempt to open the midi.library and create a "midi source" called
  709.        EDPLAYER.  Then, if there is a parameter, EdPlayer will try to make
  710.        a "Midi Route" from its source to a destination of the name
  711.        specified in the parameter.  This means that if you do NOT give a
  712.        parameter, you must create your own route with a Patch Bay before
  713.        anything can happen.  The "standard" use of this command would be
  714.        "MIDL MidiOut" because MidiOut is the standard midi.library output
  715.        to the serial port.  However, there are more useful options if you
  716.        are multitasking with other applications that use midi.library, and
  717.        want to recieve MIDI data from EdPlayer.  For instance, if you had a
  718.        MIDI monitor called "MidiMon", you could send Edplayer a
  719.        "MIDL MidiMon" to monitor EdPlayer's MIDI output.  Like the other
  720.        MIDI commands, it is safe to call MIDL even when a module is
  721.        playing, and MIDL works differently based on what resources are
  722.        already allocated.  For instance, if the serial port is allocated
  723.        when you call MIDL, it will be dumped so that midi.library can open.
  724.        Also, if midi.library was ALREADY open, MIDL won't close or re-open
  725.        it or the EDPLAYER midi_source.  It will, however, erase the old
  726.        midi route and make a new one, because routes can become useless if
  727.        their destination disappears.
  728.        NOTE that MIDL is CASE-SENSITIVE!  Use MidiOut, not MIDIout etc.
  729.        see MIDI, NOMI
  730.  
  731. PREV
  732.        EJECts current song, moves to previous song in program, and tries to
  733.        load AND PLAY it.  PREV waits for the load to complete before
  734.        returning, so it can result in all the usual load errors (file not
  735.        found, out of mem, etc.) as well as the "no program" error.  Note
  736.        that the PREV "|<" button on the panel does not work exactly like
  737.        this, because it does not automatically try to load and play.
  738.        see NEXT, JUKE
  739.  
  740. NEXT
  741.        Exactly like PREV, but moves to NEXT program selection instead of
  742.        previous one.  This command is typically used to start a program
  743.        once it's programmed in.
  744.        see PREV, JUKE
  745.  
  746. JUKE <filename>
  747.        This is the way to make EdPlayer programs from an ARexx or CLI
  748.        (telled) script.  Each call to JUKE adds the one <filename>
  749.        parameter to the end of the current program.  It's a good idea to
  750.        include the full path in this filename, because EdPlayer's current
  751.        directory may not be the same one that the script file with the
  752.        JUKEs is executing from.  Once a program is created (by a series of
  753.        "JUKE"s), the program can be started by a call to "NEXT".  Note that
  754.        calling PLAY will NOT start a program unless the first module is
  755.        already loaded, because the command PLAY does not work exactly
  756.        like the button PLAY.  So, you should start the program with NEXT.
  757. ***    NEW for EdP v1.1:  If you want to load a PP encrypted module, you
  758.        can do this:   JUKE volume:path/modulename|password
  759.        (Please note the LACK of spaces around the "|").
  760.        If you don't give a password for a mod that needs it, a password
  761.        requester opens each time the mod is loaded.  If you give a wrong
  762.        password, you will get error #5, and no requester opens.
  763.        see PREV, NEXT
  764.  
  765. *** NEW COMMANDS in EdP v1.1: ***
  766.  
  767. DCOL <decrunch color>
  768.        If you have powerpacked modules, and if you're *NOT* using
  769.        PowerPatch or some such stuff, then you can control the effect
  770.        displayed by powerpacker.library when decrunching your files.
  771.        Possible <decrunch color>s are the same as PP.lib uses:
  772.          0 = flash palette 0 on all screens
  773.          1 = flash palette 1 on all screens (EdPlayer's default)
  774.          2 = flash the mouse pointer
  775.          3 = do WEIRD FUNNY THINGS with the screen (I don't like this one)
  776.          4 = NO decrunch effect.  It just sits there, quietly decrunching.
  777.  
  778. ERAS
  779.        Nobody asked for this command, but I thought it would be more than
  780.        useful...    It erases the current program.  POOF.  Gone.
  781.        It does nothing to the current song however, so I suggest calling
  782.        both ERAS and EJEC if you want a clean sweep!
  783.  
  784. ============================================================================
  785.  
  786.                             E R R O R   C O D E S
  787.  
  788. ============================================================================
  789.  
  790. When EdPlayer gets an error, usually from an ARexx or telled command, it
  791. reports that error to the calling program.  If you use "telled", you will
  792. not see an error message in your CLI window, although errors with numbers
  793. 10 or higher may cause your script to abort.  If you use "cteled", a
  794. full error description should appear in your CLI window.  And finally, if
  795. you use an ARexx script, the error number will appear in the script's
  796. window (the script may halt for errors >= 10), but no discription will
  797. appear.  In ALL these cases, however, if the CD panel is open when the
  798. error occurs, an error number and description will appear in it.  This is
  799. useful for debugging things like DVideoIII presentations which do not even
  800. return the error number from a failed ARexx message.
  801.  
  802. If for some reason you CAN get an error number, but you would like a much
  803. fuller description, here are the codes:
  804.  
  805. 0  = No error.
  806.  
  807. 5  = Incorrect PowerPacker Password.  If you have a module that is
  808.      encrypted, and you give a wrong password, you get this!
  809.  
  810. 6  = No program!  PREV or NEXT was called, but there is no program there
  811.      to get the next songname from.
  812.  
  813. 7  = Illegal JUMP.  Someone tried to use the JUMP command to jump to a
  814.      pattern that wasn't in the song, and the command had to be ignored.
  815.  
  816. 8  = Can't continue.  CONT was called, but the song was STOPped, and could
  817.      not continue.
  818.  
  819. 9  = Nothing to PLAY!  Someone issued a PLAY with no filename and no song
  820.      currently loaded.  If you were expecting it to pull a filename from
  821.      the program in this case, you're wrong.  Use NEXT!
  822.  
  823. 10 = Syntax error.  The first four letters of the message did not make a
  824.      valid command.  Perhaps they were lower-case, or maybe there were
  825.      quotes in "telled" parameters.  Or maybe it was just garbage...
  826.  
  827. 11 = MIDI not available.  If the MIDI command returns this, then your
  828.      serial port is probably not free.  If the MIDL command returns this,
  829.      then maybe you don't have midi.library in your LIBS: directory or
  830.      something.
  831.  
  832. 12 = File not found.  A very common error.  Check spelling & path!
  833.      You must use a FULL PATH with EdPlayer, because EdPlayer's current
  834.      directory may not match the controlling program's current dir!
  835.      ALSO:  If you have two disks, both named "Empty" or both named
  836.      "ST-00" or something, EdPlayer can't tell them apart!  You will
  837.      end up seeing this error a lot.  RENAME your disks.  Make them UNIQUE!
  838.      Also, don't let req.library use "DF0:" instead of a volume name!
  839.      And, save yourself a headache:  Write the volume name of a disk
  840.      ON ITS LABEL, so that when EdPlayer asks for it, you know which one
  841.      it's asking for.
  842.  
  843. 13 = Need PowerPacker.library.  EdPlayer came across a packed module,
  844.      and you need to install powerpacker.library in your LIBS: dir.
  845.  
  846. 14 = Disk error.  Maybe the file is corrupt, or there was a read/write
  847.      error or something.
  848.  
  849. 15 = Out of memory.  There is not enough CHIP RAM to load the module.
  850.      I know that MegaBall 2.0 can load songs into FAST ram, but that is
  851.      ONLY because there are five songs, and the group of them go into
  852.      FAST together and get buffered into CHIP one song at a time.  This
  853.      method will obviously not work with EdPlayer which only loads one
  854.      song at a time anyway.  So we're stuck with CHIP RAM again.  :-(
  855.  
  856. 16 = Unknown module type, or corrupt module.  Perhaps you are trying to
  857.      play a MED 3.00 module with the MED 3.0 bug in it, or perhaps you
  858.      are trying to play an earlier format of MED modules, or even a song or
  859.      something instead of a module.  If the error happened because of a MED
  860.      mutant, just load it into MED *3.10!* and save as a MODULE.  This
  861.      should fix it.  If the tempo goes nuts, know that the MED author
  862.      changed the tempo commands and it's not my fault.  ;-)
  863.  
  864. 21 = If EdPlayer returns this, then it is exiting (shutting down). 
  865.      However, this error is much more often generated by telled itself when
  866.      it cannot find EdPlayer in the system.  For instance, if you have a
  867.      script file that starts EdPlayer, and immediately tries to send
  868.      commands to it, without waiting for it to load and get ready (open
  869.      it's port, etc.), then your script will probably die with this error
  870.      code.  You should wait for EdPlayer to start, and the best way to do
  871.      this is with the "waitport" CLI command that comes (I think) with
  872.      ARexx.  Example:  After starting EdPlayer, and before sending
  873.      commands, have the CLI execute "waitport EDPLAYER".
  874.  
  875. ============================================================================
  876.  
  877.                             W H E W ! ! ! !
  878.  
  879. ============================================================================
  880.  
  881. For those of you that read all the way through that, congratulations are in
  882. order.  I personally really hate programs who's DOC files are as big or
  883. bigger than the program itself, and so I'm not too happy about the fact
  884. that despite all my efforts to make this thing user-friendly, I still wound
  885. up with MonsterDOCs.
  886.  
  887. ----------------------------------------------------------------------------
  888.  
  889. If you use EdPlayer, or ESPECIALLY if you would like to use EdPlayer but
  890. there's some little vital feature missing that's stopping you, then I WANT
  891. to hear from you!!
  892.  
  893. For instance, if you have, say, an ASM source code that plays ST or NT mods
  894. much better than the player built into EdPlayer, send me a copy!  I'll see
  895. if I can include it in the next release or not...  (This is assuming you
  896. can legally send me this copy, and I can legally use it!  If not, DON'T.)
  897.  
  898. At this point I'm also going to suggest maybe possibly sending me a
  899. donation, if you like EdPlayer or want to see improved versions of it.  I'm
  900. not going to expect everyone who sends me mail to give a donation, just the
  901. people who want to see EdPlayer improve, or have found it useful.  Also,
  902. I'm not going to say what kind of donation.  It can be money or software or
  903. whatever, as long as it's *NOT* (a) illegal/pirated software, (b)
  904. XXX graphics, or (c) drugs, alcohol, etc.  :-(
  905.  
  906. Also I'm open to comments & suggestions about almost every aspect of the
  907. program, with the possible exception of people who think that naming the
  908. "EdPlayer" after myself was an egotistical, stuck-up move.  It's FREE
  909. software.  And I'm not a creative naming genius, obviously.  If you think
  910. YOU are, send your much-improved names, money, software, and/or comments to:
  911.  
  912. US mail:                Ed Mackey
  913.                         PO Box 475
  914.                         Wayne, PA 19087
  915.                            * USA *
  916. Or:
  917.     Internet:  ELM4@ns.cc.lehigh.edu    BITNET:  ELM4@LEHIGH.BITNET
  918.  
  919. As you might have guessed from the network addresses, I'm a student at
  920. Lehigh University in Bethlehem, PA.  I'm currently in my Junior
  921. year at Lehigh, being a Computer Science major.  This message was written
  922. on Oct 24, 1991.  I may not be at Lehigh after '93, and I may even move my
  923. home address from Wayne, PA before then, so I didn't provide EITHER of
  924. those US mail addresses here.  The only one I provided is the PO Box in
  925. Wayne (above), which I will keep EVEN if I move, so that address should be
  926. valid for years and years to come.
  927.  
  928. About my brother, Al Mackey:  He's a senior in High School.  He and I work
  929. together on programs, usually splitting the workload as follows:  All code
  930. - me.  All music - Al.  All graphics - first drawn by Al and then modified
  931. and rearranged by myself, making the gfx sort of a 50%/50% project.  This
  932. is the way we did our game Ball, our game MegaBall (Fred Fish #477), and
  933. also this project (EdPlayer).  I'm sorry I can't really distribute a bunch
  934. of Al's great music with this program, but I'm trying to keep the archive
  935. as small as I reasonably can.  Of course, Al uploads a lot of his modules
  936. to our support board, Somerton BBS (215-464-6775), where you can DL them. 
  937.  
  938. ----------------------------------------------------------------------------
  939.  
  940. Thanks for downloading EdPlayer.  Hope you like it....
  941.                                                        --Ed.
  942.